<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
   <script type="text/javascript">
   let number = 18;
    let person = {
        name:'张三',
        sex:'男'
    }

    Object.defineProperty(person,'age',{
        // value:18,
        // enumerable:true, //允许枚举 可将对象的属性展示出来
        // writable:true,//控制属性是否能被修改
        // configurable:true,//控制属性是否可以被删除

        //当有人读取person的age属性时 get函数就会被调用 且返回值就是age的值
        get:function(){
            console.log("有人读取age属性了")
            return number;
        },
        
        //当有人修改person的age属性时 set函数就会被调用 且会受到修改的具体值
        set(value){
            console.log("有人修改了age属性 且值是",value)
            number = value;
        }
    })
    console.log(Object.keys(person))
    console.log(person)
</script>
    
</body>
 

</html>